#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pll pair<ll,ll>
#define ff first
#define ss second
#define endl "\n"
#define pb push_back
const ll maxn=3e5+10;
const ll base=3e18;
const ll mod= 1e9+7;
ll n;
int main()
{
ios_base::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr);
if (fopen(".in","r"))
{
freopen("cheetos.in","r",stdin);
freopen("cheetos.out","w",stdout);
}
cin>> n;
if (n==1)
{
cout <<"1\n1 1\n";
return 0;
}
ll m= (2*n+1)/3;
cout <<m<<"\n";
while (n%3!=2)
{
cout <<n<<" "<<n<<"\n";
n--,m--;
}
vector<pll> vt;
for (int i=1;i<=(m+1)/2;i++)
vt.pb(pll(i,(m+1)/2-i+1));
for (int i=1;i<=m/2;i++)
vt.pb(pll((m+1)/2+i,m-i+1));
/* for (int i=1;i<=n;i++)
{
for (int j=1;j<=n;j++)
{
bool chk=false;
for (auto p:vt)
{
if (i==p.ff||j==p.ss)
{
chk=true;
break;
}
if (i-j==p.ff-p.ss)
{
chk=true;
break;
}
}
if (chk==false)
{
cout <<"sai cmnr"<<"\n";
return 0;
}
}
}*/
for (auto p:vt)
cout <<p.ff<<' '<<p.ss<<endl;
}
43. Multiply Strings | 34. Find First and Last Position of Element in Sorted Array |
33. Search in Rotated Sorted Array | 17. Letter Combinations of a Phone Number |
5. Longest Palindromic Substring | 3. Longest Substring Without Repeating Characters |
1312. Minimum Insertion Steps to Make a String Palindrome | 1092. Shortest Common Supersequence |
1044. Longest Duplicate Substring | 1032. Stream of Characters |
987. Vertical Order Traversal of a Binary Tree | 952. Largest Component Size by Common Factor |
212. Word Search II | 174. Dungeon Game |
127. Word Ladder | 123. Best Time to Buy and Sell Stock III |
85. Maximal Rectangle | 84. Largest Rectangle in Histogram |
60. Permutation Sequence | 42. Trapping Rain Water |
32. Longest Valid Parentheses | Cutting a material |
Bubble Sort | Number of triangles |
AND path in a binary tree | Factorial equations |
Removal of vertices | Happy segments |
Cyclic shifts | Zoos |